Mengukur Downside Risk dengan VaR dan CVaR

Seperti kita bahas dalam studi sebelumnya, distribusi dari keuntungan biasanya bukanlah normal, sehingga pemakaian standar deviasi kurang tepat karena standar deviasi mengasumsikan distibusi yang simetris dan kurtosis yang tipis. Sementara dalam manajemen portfolio, investor biasanya lebih menguatirkan resiko untuk mengalami kerugian yang besar, atau probabilitas dari return negatif yang besar, daripada volatilitas dari laba (tentu kita tidak keberatan kalau suatu saat labanya melonjak tinggi).

Atas pemikiran ini maka diciptakan perhitungan-perhitungan untuk lebih spesifik mengukur resiko atas kerugian (downside risk), yang akan kita bahas dalam studi ini.

Semi-Deviation

Semi-Deviation adalah ukuran volatilitas dari return yang di bawah rata-rata. Semi-deviation dihitung dengan menghitung standard deviasi dari return yang di bawah rata-ratanya:

$$ \sigma_{semi} = \sqrt{ \frac{1}{N} \sum_{R_t < \overline{R}} (R_t - \overline{R})^2 }$$

(catatan: N adalah jumlah sampel dari return yang di bawah rata-rata)

Atau praktisnya, untuk suatu data returns, kita hitung rata-ratanya, lalu buang sampel yang nilainya di atas atau sama-dengan rata-rata, lalu hitung standard deviasi dari sampel yang tersisa.

Semi-deviation mengukur volatilitas dari return yang di bawah rata-ratanya, namun tidak memberikan informasi resiko kerugian besar yang bisa dialami investor. Untuk itu kita bisa memakai perhitungan yang lain berikut ini.

Untuk mendemonstrasikan perhitungan semi-deviation, mari kita membuat data random sbb.


In [2]:
import numpy as np
import pandas as pd

np.random.seed(0)
returns = pd.Series(np.random.normal(0, 0.10, 100)).sort_values()
returns.values


Out[2]:
array([-0.25529898, -0.19807965, -0.17262826, -0.17062702, -0.16301983,
       -0.16138978, -0.15362437, -0.14543657, -0.14200179, -0.12527954,
       -0.12348258, -0.11806322, -0.11651498, -0.10707526, -0.1048553 ,
       -0.09772779, -0.09072984, -0.08954666, -0.08877857, -0.08707971,
       -0.08540957, -0.08131463, -0.0742165 , -0.06848101, -0.06724604,
       -0.06343221, -0.05788497, -0.05108051, -0.05096522, -0.04380743,
       -0.04031769, -0.04017809, -0.03873268, -0.03627412, -0.03595532,
       -0.03479121, -0.03115525, -0.03023028, -0.02127403, -0.02051583,
       -0.01871839, -0.01799248, -0.01513572, -0.01032189, -0.00281822,
        0.00105   ,  0.00457585,  0.00519454,  0.00561653,  0.00665172,
        0.0121675 ,  0.01269121,  0.01289829,  0.01440436,  0.01549474,
        0.0156349 ,  0.01774261,  0.0208275 ,  0.03024719,  0.03130677,
        0.03336743,  0.03563664,  0.03781625,  0.03869025,  0.04001572,
        0.04019894,  0.04023416,  0.04105985,  0.04283319,  0.04438632,
        0.04627823,  0.04656624,  0.06536186,  0.07065732,  0.07290906,
        0.07610377,  0.07774904,  0.08644362,  0.09008265,  0.09500884,
        0.0976639 ,  0.0978738 ,  0.10544517,  0.11394007,  0.11787796,
        0.12023798,  0.12224451,  0.12302907,  0.14542735,  0.14693588,
        0.14882522,  0.14940791,  0.15327792,  0.17640523,  0.17858705,
        0.1867558 ,  0.18958892,  0.19507754,  0.22408932,  0.22697546])

Berikut untuk menghitung semi-deviation. Catatan: kadang-kadang semi-deviation juga dihitung dari returns yang di bawah nol (bukan di bawah rata-rata). Perhitungan seperti ini yang kita pakai.


In [3]:
semi_dev = returns[ returns < 0 ].std(ddof=0)
semi_dev


Out[3]:
0.05697869944961799

Value at Risk (VaR)

Value at Risk (VaR) mengukur maksimum kerugian yang bisa dialami dari suatu investasi setelah kasus kerugian ekstrim dihilangkan. Jadi 95% Value at Risk berarti maksimum kerugian yang bisa dialami setelah 5% kerugian yang paling ekstrim dihilangkan.

Angka 95% ini, disebut confidence level, dan bisa diganti dengan yang lain sesuai kebutuhan, misalnya 99% atau 99.9%.

VaR bisa dipakai oleh manajer investasi untuk menyisihkan cadangan modal yang dipakai untuk menutup kemungkinan kerugian terburuk yang bisa dialami.

Untuk menghitung VaR, pertama tentukan batas confidence level-nya, misalkan 95%. Karena batasnya 95%, maka buang 5% data return yang terendah. Lalu ambil return terendah dari data return yang tersisa, lalu dijadikan positif. Itulah nilai VaR-nya.

Untuk menghitung 95% VaR dari data di atas, pertama kita hilangkan 5% data return terburuk, atau dalam hal ini berarti kita hilangkan lima sampel. Nilai VaR-nya adalah nilai terburuk yang tersisa (-0.16138978) lalu kita positifkan (menjadi 0.16138978).

Artinya, dalam 95% kemungkinan, kerugian terburuk investasi kita adalah minus 0.16138978 atau minus 16%.

Cara lain untuk menghitung VaR adalah dengan memanggil fungsi np.percentile() seperti di bawah ini.


In [4]:
np.percentile(returns, 5)


Out[4]:
-0.16147128725283563

Nilai di atas sedikit berbeda dengan perhitungan manual kita karena np.percentile() mengandung interpolasi. Dan jangan lupa bahwa nilai VaR adalah positif (jadi nilai di atas harus dipositifkan).

Conditional Value at Risk (CVaR)

Dalam kondisi lain, mungkin kita ingin melihat karakteristik dari kerugian terburuk di luar VaR. Seperti contoh di atas, kita sudah hitung bahwa VaR-nya adalah 16%. Bagaimana kalau kasus terburuk (yaitu kasus yg 5% itu) benar-benar terjadi? Berapa kerugiannya? Jangan-jangan kerugiannya sangat ekstrim yang membuat kita bangkrut!

Karakteristik inilah yang diukur oleh Conditional Value at Risk (CVaR).

Perhitungan CVaR sederhana saja. Cukup kita hitung nilai rata-rata dari return terburuk yang kita buang ketika menghitung VaR tadi, lalu kita positifkan.

Dengan contoh di atas, CVaR berarti nilai absolut dari rata-rata 5 kerugian terburuk, yang bisa kita hitung seperti ini:


In [5]:
cvar = np.abs(returns[:5].mean())
cvar


Out[5]:
0.1919307484796148

Cara Perhitungan VaR yang Lain

Metoda penghitungan VaR yang kita pakai di atas memakai metoda historis. Keuntungan dari perhitungan secara historis adalah perhitungan ini tidak membutuhkan asumsi apapun, sedangkan kerugiannya adalah sensitivitas terhadap data (kalau datanya berubah, mungkin nilai VaR akan berubah secara signifikan).

Dengan kata lain, metoda itu mempunyai resiko akibat model (model risk) yang kecil, namun resiko akibat sampelnya (sample risk) besar.

Ada beberapa cara lain untuk menghitung VaR.

Metoda Gaussian

Dengan mengasumsikan bahwa distribusi return-nya adalah normal, maka kita dapat menghitung berapa nilai VaR untuk suatu probabilitas atau confidence level.

Misalkan kita mau menghitung 95% VaR, maka $ \alpha $ adalah 0.05 (=100% - 95%), seperti dalam gambar berikut.

Dari tabel z-table kita bisa tahu bahwa nilai $ z $ yang sesuai adalah -1.645.

Maka nilai VaR dapat dihitung dengan:

$$ VaR = -(\mu - 1.645\ \sigma) $$

Formula perhitungan generiknya adalah:

$$ VaR_{\alpha} = -(\mu + z_{\alpha} \ \sigma) $$

dimana:

  • $ VaR_{\alpha} $ : VaR untuk quantile $ \alpha $
  • $ \mu $ : mean
  • $ z_{\alpha} $ : z-value untuk quantile $ \alpha $ (lihat z-table)
  • $ \sigma $ : standard deviasi

Implementasinya dalam Python adalah sbb.:


In [6]:
from scipy.stats import norm

def get_gaussian_var(returns, alpha):
    mean = returns.mean()
    std = returns.std(ddof=0)
    z = norm.ppf(alpha)
    var = -(mean + z * std)
    return var

get_gaussian_var(returns, 0.05)


Out[6]:
0.1598010750227573

Seperti kita lihat, nilainya dekat dengan perhitungan-perhitungan sebelumnya. Namun harap diingat, bahwa untuk contoh ini, nilai returns-nya berasal dari angka random dengan distribusi normal. Kalau distribusi nilai returns nya bukan normal, maka hasil perhitungan bisa berbeda jauh. Dan memang inilah kelemahan dari perhitungan dengan metoda ini, yaitu mengasumsikan distribusi normal, padahal kita telah belajar sebelumnya bahwa kemungkinan besar bukan.

Dengan kata lain, metoda Gaussian mempunyai model risk yang besar, dan sample risk yang kecil.

Di sisi lain, perhitungan ini hanya membutuhkan nilai mean dan standard deviasi, jadi sangat simpel.

Secara umum, cara ini kurang tepat dipakai untuk menghitung VaR, karena VaR menghitung nilai pada ekor distribusi, sedangkan justru bagian ekor dari distribusi return yang karakteristiknya berbeda dengan distribusi normal (tebal vs tipis).

Metoda Cornish-Fisher

Metoda Cornish-Fisher juga mengasumsikan bahwa return mengikuti suatu distribusi, namun distribusinya bisa disesuaikan untuk nilai skew dan kurtosis tertentu. Penyesuaian ini disebut Cornish-Fisher expansion.

Cornish-Fisher pada dasarnya adalah nilai $ z_\alpha $ yang disesuaikan, dimana penyesuaiannya melibatkan skewness $ S $ dan kurtosis $ K $. Jika skewness nol dan kurtosis tiga, maka nilai $ \widetilde{z_\alpha} $ akan sama dengan nilai $ z_\alpha $.

Berikut adalah perhitungan VaR dengan koreksi Cornish-Fisher dalam Python.


In [7]:
from scipy.stats import skew, kurtosis

def get_cornish_fisher_var(returns, alpha):
    z = norm.ppf(alpha)
    s = skew(returns)
    k = kurtosis(returns, fisher=False)
    z = (z +
         (z**2 - 1)*s/6 +
         (z**3 -3*z)*(k-3)/24 -
         (2*z**3 - 5*z)*(s**2)/36)
    var = -(returns.mean() + z * returns.std(ddof=0))
    return var
         
get_cornish_fisher_var(returns, 0.05)


Out[7]:
0.16042241851466338

Metoda perhitungan Cornish-Fisher ini dianggap sebagai titik tengah yang bagus antara model risk dan sample risk. Metoda ini cukup populer dipakai.

Referensi dan Atribusi

Sebagian besar materi di sini diambil dari materi minggu 1 dari MOOC Introduction to Portfolio Construction and Analysis with Python.


In [ ]: